package com.alex.wechat.mp.accountmgr.controller;

import java.io.IOException;
import java.net.URI;
import java.util.ArrayList;
import java.util.List;
import java.util.Map;
import java.util.Set;

import javax.servlet.http.HttpServletRequest;
import javax.servlet.http.HttpServletResponse;
import javax.validation.ConstraintViolation;
import javax.validation.Validator;

import org.apache.log4j.Logger;
import org.jeecgframework.core.beanvalidator.BeanValidators;
import org.jeecgframework.core.common.controller.BaseController;
import org.jeecgframework.core.common.exception.BusinessException;
import org.jeecgframework.core.common.hibernate.qbc.CriteriaQuery;
import org.jeecgframework.core.common.model.json.AjaxJson;
import org.jeecgframework.core.common.model.json.DataGrid;
import org.jeecgframework.core.constant.Globals;
import org.jeecgframework.core.util.ExceptionUtil;
import org.jeecgframework.core.util.MutiLangUtil;
import org.jeecgframework.core.util.MyBeanUtils;
import org.jeecgframework.core.util.ResourceUtil;
import org.jeecgframework.core.util.StringUtil;
import org.jeecgframework.core.util.oConvertUtils;
import org.jeecgframework.poi.excel.ExcelImportUtil;
import org.jeecgframework.poi.excel.entity.ExportParams;
import org.jeecgframework.poi.excel.entity.ImportParams;
import org.jeecgframework.poi.excel.entity.vo.NormalExcelConstants;
import org.jeecgframework.tag.core.easyui.TagUtil;
import org.jeecgframework.web.system.pojo.base.TSUser;
import org.jeecgframework.web.system.service.SystemService;
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.http.HttpHeaders;
import org.springframework.http.HttpStatus;
import org.springframework.http.MediaType;
import org.springframework.http.ResponseEntity;
import org.springframework.stereotype.Controller;
import org.springframework.ui.ModelMap;
import org.springframework.web.bind.annotation.PathVariable;
import org.springframework.web.bind.annotation.RequestBody;
import org.springframework.web.bind.annotation.RequestMapping;
import org.springframework.web.bind.annotation.RequestMethod;
import org.springframework.web.bind.annotation.ResponseBody;
import org.springframework.web.bind.annotation.ResponseStatus;
import org.springframework.web.multipart.MultipartFile;
import org.springframework.web.multipart.MultipartHttpServletRequest;
import org.springframework.web.servlet.ModelAndView;
import org.springframework.web.util.UriComponentsBuilder;

import com.alex.wechat.mp.account.entity.WxAccountEntity;
import com.alex.wechat.mp.accountmgr.entity.WxAccountMgrEntity;
import com.alex.wechat.mp.accountmgr.service.WxAccountMgrServiceI;

/**
 * @Title: Controller
 * @Description: 公众号管理员
 * @author onlineGenerator
 * @date 2016-11-19 21:33:00
 * @version V1.0
 *
 */
@Controller
@RequestMapping("/wxAccountMgrController")
public class WxAccountMgrController extends BaseController {
  /**
   * Logger for this class
   */
  private static final Logger logger = Logger.getLogger(WxAccountMgrController.class);

  @Autowired
  private WxAccountMgrServiceI wxAccountMgrService;
  @Autowired
  private SystemService systemService;
  @Autowired
  private Validator validator;

  /**
   * 公众号管理员列表 页面跳转
   * 
   * @return
   */
  @RequestMapping(params = "list")
  public ModelAndView list(HttpServletRequest request) {
    return new ModelAndView("com/gomore/wechat/mp/accountmgr/wxAccountMgrList");
  }

  /**
   * easyui AJAX请求数据
   * 
   * @param request
   * @param response
   * @param dataGrid
   * @param user
   */

  @RequestMapping(params = "datagrid")
  public void datagrid(WxAccountMgrEntity wxAccountMgr, HttpServletRequest request,
      HttpServletResponse response, DataGrid dataGrid) {
    CriteriaQuery cq = new CriteriaQuery(WxAccountMgrEntity.class, dataGrid);
    // 查询条件组装器
    org.jeecgframework.core.extend.hqlsearch.HqlGenerateUtil.installHql(cq, wxAccountMgr,
        request.getParameterMap());
    try {
      // 自定义追加查询条件
    } catch (Exception e) {
      throw new BusinessException(e.getMessage());
    }
    cq.add();
    this.wxAccountMgrService.getDataGridReturn(cq, true);
    TagUtil.datagrid(response, dataGrid);
  }

  /**
   * 删除公众号管理员
   * 
   * @return
   */
  @RequestMapping(params = "doDel")
  @ResponseBody
  public AjaxJson doDel(WxAccountMgrEntity wxAccountMgr, HttpServletRequest request) {
    String message = null;
    AjaxJson j = new AjaxJson();
    wxAccountMgr = systemService.getEntity(WxAccountMgrEntity.class, wxAccountMgr.getId());
    message = "公众号管理员删除成功";
    try {
      wxAccountMgrService.delete(wxAccountMgr);
      systemService.addLog(message, Globals.Log_Type_DEL, Globals.Log_Leavel_INFO);
    } catch (Exception e) {
      e.printStackTrace();
      message = "公众号管理员删除失败";
      throw new BusinessException(e.getMessage());
    }
    j.setMsg(message);
    return j;
  }

  /**
   * 批量删除公众号管理员
   * 
   * @return
   */
  @RequestMapping(params = "doBatchDel")
  @ResponseBody
  public AjaxJson doBatchDel(String ids, HttpServletRequest request) {
    String message = null;
    AjaxJson j = new AjaxJson();
    message = "公众号管理员删除成功";
    try {
      for (String id : ids.split(",")) {
        WxAccountMgrEntity wxAccountMgr = systemService.getEntity(WxAccountMgrEntity.class, id);
        wxAccountMgrService.delete(wxAccountMgr);
        systemService.addLog(message, Globals.Log_Type_DEL, Globals.Log_Leavel_INFO);
      }
    } catch (Exception e) {
      e.printStackTrace();
      message = "公众号管理员删除失败";
      throw new BusinessException(e.getMessage());
    }
    j.setMsg(message);
    return j;
  }

  /**
   * 添加公众号管理员
   * 
   * @param ids
   * @return
   */
  @RequestMapping(params = "doAdd")
  @ResponseBody
  public AjaxJson doAdd(WxAccountMgrEntity wxAccountMgr, HttpServletRequest request) {
    String message = null;
    AjaxJson j = new AjaxJson();
    message = "公众号管理员添加成功";
    try {
      wxAccountMgrService.save(wxAccountMgr);
      systemService.addLog(message, Globals.Log_Type_INSERT, Globals.Log_Leavel_INFO);
    } catch (Exception e) {
      e.printStackTrace();
      message = "公众号管理员添加失败";
      throw new BusinessException(e.getMessage());
    }
    j.setMsg(message);
    return j;
  }

  /**
   * 更新公众号管理员
   * 
   * @param ids
   * @return
   */
  @RequestMapping(params = "doUpdate")
  @ResponseBody
  public AjaxJson doUpdate(WxAccountMgrEntity wxAccountMgr, HttpServletRequest request) {
    String message = null;
    AjaxJson j = new AjaxJson();
    message = "公众号管理员更新成功";
    WxAccountMgrEntity t = wxAccountMgrService.get(WxAccountMgrEntity.class, wxAccountMgr.getId());
    try {
      MyBeanUtils.copyBeanNotNull2Bean(wxAccountMgr, t);
      wxAccountMgrService.saveOrUpdate(t);
      systemService.addLog(message, Globals.Log_Type_UPDATE, Globals.Log_Leavel_INFO);
    } catch (Exception e) {
      e.printStackTrace();
      message = "公众号管理员更新失败";
      throw new BusinessException(e.getMessage());
    }
    j.setMsg(message);
    return j;
  }

  /**
   * 公众号管理员新增页面跳转
   * 
   * @return
   */
  @RequestMapping(params = "goAdd")
  public ModelAndView goAdd(WxAccountMgrEntity wxAccountMgr, HttpServletRequest req) {
    if (StringUtil.isNotEmpty(wxAccountMgr.getId())) {
      wxAccountMgr = wxAccountMgrService.getEntity(WxAccountMgrEntity.class, wxAccountMgr.getId());
      req.setAttribute("wxAccountMgrPage", wxAccountMgr);
    }
    return new ModelAndView("com/gomore/wechat/mp/accountmgr/wxAccountMgr-add");
  }

  /**
   * 公众号管理员编辑页面跳转
   * 
   * @return
   */
  @RequestMapping(params = "goUpdate")
  public ModelAndView goUpdate(WxAccountMgrEntity wxAccountMgr, HttpServletRequest req) {
    if (StringUtil.isNotEmpty(wxAccountMgr.getId())) {
      wxAccountMgr = wxAccountMgrService.getEntity(WxAccountMgrEntity.class, wxAccountMgr.getId());
      req.setAttribute("wxAccountMgrPage", wxAccountMgr);
    }
    return new ModelAndView("com/gomore/wechat/mp/accountmgr/wxAccountMgr-update");
  }

  /**
   * 导入功能跳转
   * 
   * @return
   */
  @RequestMapping(params = "upload")
  public ModelAndView upload(HttpServletRequest req) {
    req.setAttribute("controller_name", "wxAccountMgrController");
    return new ModelAndView("common/upload/pub_excel_upload");
  }

  /**
   * 导出excel
   * 
   * @param request
   * @param response
   */
  @RequestMapping(params = "exportXls")
  public String exportXls(WxAccountMgrEntity wxAccountMgr, HttpServletRequest request,
      HttpServletResponse response, DataGrid dataGrid, ModelMap modelMap) {
    CriteriaQuery cq = new CriteriaQuery(WxAccountMgrEntity.class, dataGrid);
    org.jeecgframework.core.extend.hqlsearch.HqlGenerateUtil.installHql(cq, wxAccountMgr,
        request.getParameterMap());
    List<WxAccountMgrEntity> wxAccountMgrs = this.wxAccountMgrService.getListByCriteriaQuery(cq,
        false);
    modelMap.put(NormalExcelConstants.FILE_NAME, "公众号管理员");
    modelMap.put(NormalExcelConstants.CLASS, WxAccountMgrEntity.class);
    modelMap.put(NormalExcelConstants.PARAMS, new ExportParams("公众号管理员列表",
        "导出人:" + ResourceUtil.getSessionUserName().getRealName(), "导出信息"));
    modelMap.put(NormalExcelConstants.DATA_LIST, wxAccountMgrs);
    return NormalExcelConstants.JEECG_EXCEL_VIEW;
  }

  /**
   * 导出excel 使模板
   * 
   * @param request
   * @param response
   */
  @RequestMapping(params = "exportXlsByT")
  public String exportXlsByT(WxAccountMgrEntity wxAccountMgr, HttpServletRequest request,
      HttpServletResponse response, DataGrid dataGrid, ModelMap modelMap) {
    modelMap.put(NormalExcelConstants.FILE_NAME, "公众号管理员");
    modelMap.put(NormalExcelConstants.CLASS, WxAccountMgrEntity.class);
    modelMap.put(NormalExcelConstants.PARAMS, new ExportParams("公众号管理员列表",
        "导出人:" + ResourceUtil.getSessionUserName().getRealName(), "导出信息"));
    modelMap.put(NormalExcelConstants.DATA_LIST, new ArrayList());
    return NormalExcelConstants.JEECG_EXCEL_VIEW;
  }

  @SuppressWarnings("unchecked")
  @RequestMapping(params = "importExcel", method = RequestMethod.POST)
  @ResponseBody
  public AjaxJson importExcel(HttpServletRequest request, HttpServletResponse response) {
    AjaxJson j = new AjaxJson();

    MultipartHttpServletRequest multipartRequest = (MultipartHttpServletRequest) request;
    Map<String, MultipartFile> fileMap = multipartRequest.getFileMap();
    for (Map.Entry<String, MultipartFile> entity : fileMap.entrySet()) {
      MultipartFile file = entity.getValue();// 获取上传文件对象
      ImportParams params = new ImportParams();
      params.setTitleRows(2);
      params.setHeadRows(1);
      params.setNeedSave(true);
      try {
        List<WxAccountMgrEntity> listWxAccountMgrEntitys = ExcelImportUtil
            .importExcel(file.getInputStream(), WxAccountMgrEntity.class, params);
        for (WxAccountMgrEntity wxAccountMgr : listWxAccountMgrEntitys) {
          wxAccountMgrService.save(wxAccountMgr);
        }
        j.setMsg("文件导入成功！");
      } catch (Exception e) {
        j.setMsg("文件导入失败！");
        logger.error(ExceptionUtil.getExceptionMessage(e));
      } finally {
        try {
          file.getInputStream().close();
        } catch (IOException e) {
          e.printStackTrace();
        }
      }
    }
    return j;
  }

  @RequestMapping(method = RequestMethod.GET)
  @ResponseBody
  public List<WxAccountMgrEntity> list() {
    List<WxAccountMgrEntity> listWxAccountMgrs = wxAccountMgrService
        .getList(WxAccountMgrEntity.class);
    return listWxAccountMgrs;
  }

  @RequestMapping(value = "/{id}", method = RequestMethod.GET)
  @ResponseBody
  public ResponseEntity<?> get(@PathVariable("id") String id) {
    WxAccountMgrEntity task = wxAccountMgrService.get(WxAccountMgrEntity.class, id);
    if (task == null) {
      return new ResponseEntity(HttpStatus.NOT_FOUND);
    }
    return new ResponseEntity(task, HttpStatus.OK);
  }

  @RequestMapping(method = RequestMethod.POST, consumes = MediaType.APPLICATION_JSON_VALUE)
  @ResponseBody
  public ResponseEntity<?> create(@RequestBody WxAccountMgrEntity wxAccountMgr,
      UriComponentsBuilder uriBuilder) {
    // 调用JSR303 Bean Validator进行校验，如果出错返回含400错误码及json格式的错误信息.
    Set<ConstraintViolation<WxAccountMgrEntity>> failures = validator.validate(wxAccountMgr);
    if (!failures.isEmpty()) {
      return new ResponseEntity(BeanValidators.extractPropertyAndMessage(failures),
          HttpStatus.BAD_REQUEST);
    }

    // 保存
    try {
      wxAccountMgrService.save(wxAccountMgr);
    } catch (Exception e) {
      e.printStackTrace();
      return new ResponseEntity(HttpStatus.NO_CONTENT);
    }
    // 按照Restful风格约定，创建指向新任务的url, 也可以直接返回id或对象.
    String id = wxAccountMgr.getId();
    URI uri = uriBuilder.path("/rest/wxAccountMgrController/" + id).build().toUri();
    HttpHeaders headers = new HttpHeaders();
    headers.setLocation(uri);

    return new ResponseEntity(headers, HttpStatus.CREATED);
  }

  @RequestMapping(value = "/{id}", method = RequestMethod.PUT,
      consumes = MediaType.APPLICATION_JSON_VALUE)
  public ResponseEntity<?> update(@RequestBody WxAccountMgrEntity wxAccountMgr) {
    // 调用JSR303 Bean Validator进行校验，如果出错返回含400错误码及json格式的错误信息.
    Set<ConstraintViolation<WxAccountMgrEntity>> failures = validator.validate(wxAccountMgr);
    if (!failures.isEmpty()) {
      return new ResponseEntity(BeanValidators.extractPropertyAndMessage(failures),
          HttpStatus.BAD_REQUEST);
    }

    // 保存
    try {
      wxAccountMgrService.saveOrUpdate(wxAccountMgr);
    } catch (Exception e) {
      e.printStackTrace();
      return new ResponseEntity(HttpStatus.NO_CONTENT);
    }

    // 按Restful约定，返回204状态码, 无内容. 也可以返回200状态码.
    return new ResponseEntity(HttpStatus.NO_CONTENT);
  }

  @RequestMapping(value = "/{id}", method = RequestMethod.DELETE)
  @ResponseStatus(HttpStatus.NO_CONTENT)
  public void delete(@PathVariable("id") String id) {
    wxAccountMgrService.deleteEntityById(WxAccountMgrEntity.class, id);
  }

  /**
   * 添加 用户到组织机构 的页面 跳转
   * 
   * @param req
   *          request
   * @return 处理结果信息
   */
  @RequestMapping(params = "goAddMgr")
  public ModelAndView goAddMgr(HttpServletRequest req) {
    req.setAttribute("accountid", req.getParameter("accountid"));
    return new ModelAndView("com/gomore/wechat/mp/accountmgr/noCurAccountMgrList");
  }

  /**
   * 添加 用户到组织机构
   * 
   * @param req
   *          request
   * @return 处理结果信息
   */
  @RequestMapping(params = "doAddMgrToWxAccount")
  @ResponseBody
  public AjaxJson doAddMgrToWxAccount(HttpServletRequest req) {
    String message = null;
    AjaxJson j = new AjaxJson();
    WxAccountEntity account = systemService.getEntity(WxAccountEntity.class,
        req.getParameter("accountid"));
    saveAccountMgrs(req, account);
    message = MutiLangUtil.paramAddSuccess("common.user");
    // systemService.addLog(message, Globals.Log_Type_UPDATE,
    // Globals.Log_Leavel_INFO);
    j.setMsg(message);
    return j;
  }

  /**
   * 保存公众号管理员
   * 
   * @param request
   *          request
   * @param account
   *          depart
   */
  private void saveAccountMgrs(HttpServletRequest request, WxAccountEntity account) {
    String orgIds = oConvertUtils.getString(request.getParameter("userIds"));

    List<WxAccountMgrEntity> accountMgsList = new ArrayList<WxAccountMgrEntity>();
    List<String> userIdList = extractIdListByComma(orgIds);
    for (String userId : userIdList) {
      TSUser user = systemService.getEntity(TSUser.class, userId);
      WxAccountMgrEntity accountMgr = new WxAccountMgrEntity();
      accountMgr.setAccountId(account.getId());
      accountMgr.setUserId(userId);
      accountMgr.setUserName(user.getUserName());
      accountMgr.setRealName(user.getRealName());
      accountMgsList.add(accountMgr);
    }

    if (!accountMgsList.isEmpty()) {
      systemService.batchSave(accountMgsList);
    }
  }

}
